MAD 8 


UN DÉSASSEMBLEUR POUR 8008 | 


JÉRÔME CHAILLOUX 


ARTINFO/MUSINFO #28 


http:/Awww.artinfo-musinfo.org Artinfo Musinfo # 28, mars 1978, page 11 / 56 


http:/Awww.artinfo-musinfo.org Artinfo Musinfo # 28, mars 1978, page 12 / 56 


MANS un desassembleur rour 8008 


ALIS 
MAT B 
OOOO Ro KK 


Jerome CHAILLOUX 
Fevrier 1977 


MATDB est un desassembleur de rubans rerfores hexadecimal 
issus du micro-rrocesseur 8008. Il rermet d’obtenir des 
listeses "en clair" de vos rrogrammes a partir d'un ruban 
rerfore, MATS fonctionne sur le T1609., 


1,0 Les rubans hexadecimaux. 


Les rubans hexedecimaux imasges-memoire sont Produits au 
towen des commandes My E et N du moniteur 8008, Ces rubans 
ne contiennent que des caracteres imerimables et reuvent 


done etre relus sur ume TTY non connectee (TTY en mode 
local), 


LL Le commande N (rull command) 


oe 


syntaxe oN 


rerfore une avance bande de 60 caracteres mulls (code 00). 


1.2 Ja commande W (write command) 


suntare ? «Y adresse de debut » adresse de fin 


rerfore (dang le format decrit ci-dessous) l’imase le la 
zone memoire commencant et se terminant aux adresses sreci- 
fiees cans la commande. On pe も emettre rlusieurs commandes 
W 3 la suite pour obtenirs sur le meme ruban rhusiaues les 
images de zones memoires non-contistes. 
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1.3 la commande E Cend-of-file commarde) 


gaumbtaxe à ¿E adresse de lancement 


perfore un bloc "fin de ruban" (voir son format ci-dessous) 
aui contient ‘adresse de lancement du erogramme. Cette 
commande rerfore en outre une avance bande e 


1,4 enchainement des commandes de rerforation. 


oN }--rerforation d'une lere avance bande, 
¿Whihhhs hhh 
+++ 
++ -- perforation des differentes zones memoires 
++: 
>。Mhhhh yhhhh 
Exxx ` }-.rerforation de l'adresse de lancement 


et d'une fin de bande. 


1,5 format des rubans hexadecimaux 


Tis sont formes d’enregistrements oui possedent tous la meme 
structure, Chague octet est rerresente par deux digits hex- 
adecimaux (hh). 


* hh hhhh 00 hh s. +. hh hh 
1 

1 1 | i octet de cheksumr calcule de telle 
ti ! maniere pue la somme de tous les 
U t t $ H H 
e a 1 i , octets de l“enresistrement (y 
d ' 1 R comeris le nombre de donmees» 
6 i 1 i i l'adresse de l’octet de cheksum 
Ys l i 4 lui meme) soit esale a OG, 
i i ) i 
y | 1 n octets de donnees a charger en memoire a 
' i 1 i rartir de l'adresse srécifiee. Le nombre r 
1 À ! b est le ler octet de l'enregistrement. 
i 4 t 

i . : R 
! ìi 4 ture de l'enregistrement (toujours 00), 
i 

i 

D 
| ) adresse memoire (sur 2 octets) ou il faut charger 
, + des donnees « 

1 
‘ ` 
y hombre d'octets de donnees a charger en memoire: 
i 


caractere "i" destine a marauer le debut de 
l'enregistrement. 
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La fin losgiaue du ruban est detectee par oun enresistrement 
dont le nombre de donnees a charder est esal a zero. 
3 00 hhhh 00 hh 

A ZE) =< 

U U D 

W ` H H . 

o: : LI octet de chek sium 

U e 

o : toujours 00, 

D U A 

» ! adresse de lancement du rrogramne. 

a é D 

à haraue de fir de- rubar Llosiaue. 

a 


margue de debut d/eanredistrement. 


2,0 Princire du desassembleur. 


Les rubans hexadecimaux sont tres utiles rour garder des 
rrogremmes sous un format tres reduits en revancher ils sort 
peu commodes pour documenters modifier ou meme comrrendre 
ces memes rrosrammes. MAS va editer chaaue octet code du 
ruban rerfore sous les differents formats € 

… mnemoniaue instruction CINTELGREU) +. 

- valeur hexadecimale 

… caractere ASCII, 


Les instructions du 8008 etant de longeur variables les re~ 
sulats ainsi obtenus sant tres mediocres sour le listase des 
instructions. Far exemple le desassemblese des 3 octets 
corresrondant a l'instruction JME 1000 rroduit l’edition de 


+ 
+ 


JMF 44 D 
HLT OO 了 
INC 10 ? 


MAUS va s'efforcer de distinguer dans l’image memoire les 
zones contenant des instructions, des zones contenant des 
donnees, Four ce fairey MALS va simuler l’execution du ero- 
gramme a partir de son adresse de lancement» et marauer les 


octets oui sont consideres comme des instructions. Cette 
simulation consiste a interrereter les instructions oui Pro” 
vogue des rurtures de sequence isee les instructions de 


tyre HLT» JMFy CALs KET et RST; conditionnelles ou incondi- 
tionnelles. Ce marausde ne reut s'effectuer au’arres avoir 
charge en entier le errosramme a desassemblere 


Une fois le marauese effectues MAIS edite l’image memoire 
sous les formats instructions ou donnees: 


Ce principe a toutefois des limitations. Les branchements 
indirects et/ou indexes me Peuvent ras etre interrretes, 
Les donnees ne doivent ras etre melanstees au programme, Er 


particulier les arrels de sous-rrodrammes dont les arguments 
sont rlaces Juste en dessous de l'arrel effectif risque de 
placer MADB dans un etat de confusion derlorable,s 
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MALS un desassembleur rour 8008 


3,0 wtilisation du desassembleur. 


MALS est ur utilitaire standard du T1600 oui utilise 


differentes FUs ? 


BI entree du ruban hexa 


ーー シン N 


_ listase du desassemblase 
AE) AO | 
i リオ メメ メル アルタ ルル 4 


FC commandes de MATE 


3,1 activation de MANS 


KCALL MAD arrel du programme MADB. Si  BOS/0 imprime - 


message d'erreur ERE O6» le programme ni 
sur le disauef il me vous reste Plus. o 
sassembler votre programme a a la main 
mettre MAUR sur le disque. 


XEI TR affectation du lecteur de ruban 
XEO TK affectation du clavier TTY rour entrer les 


mandes de MAT, 


*LO LE affectation de L’imerimante Four le 
final. 


3.2 commandes MAIS 


xIMAT initialise MANS et lit le ler ruban sur 
g HT, Cette. commande est obligatoire et ne doit 


etre emise au‘une seule fois sous reine de 


dre l’image memoire oul avait ete cree. 
Ou 
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MADS ne reut simuler aue les 8 lers k du 8008, 
Si vous voulez desassembler des programmes en 
REFROM (Cie des srogremmes dont l’adresse est 
plus grande que 2000 hexa), vous rouvez srecif- 
jer dans la commande la lere adresse a simuler, 

XIMAlrhhhh Cette deuxieme forme n'est dons ras e utiliser 
pour des rogrammes en RAM, 


XCMAII permet de Lire d'autres rubans sans reiniti- 
aliser le systemes si votre votre rrogramme se 
trouve sur plusieurs. rubans rerfores, Cette 


commande peut etre emise rlusieurs fois. 


EMMAL marane L'imese memoire, On surrose que la rrem- 
iere adresse du programme (som adresse de lence- 
ment) a ete lue sur le bloc fin de rubar du der- 
nier ruban Lts | 

KMMAlirhhhh marque l’image memoire a Partir de l'adresse 
geecafiee dans la commande, Cette commande reut 
etre emise plusieurs fois en rarticulier Four 
srecifier les differentes adresses se trouvant 
dans une table de branchements indirects 
indexes. 


SL Mot edite sur L'unite LO le resultat du desassem- 
tlase, Cette commande reut etre emise plusieurs 
fois Four obtenir rlusieurs cories du desassem- 

blades ーー | | 


SEO. fin d “execution de MALTS, 


343 utilisation du disaue 


Le lecteur de ruban de la TTY est tres lent. Il est rarfois 
avantadeux de creer unm fichier sur diseue contenant l’image 
du ruban hexadecimal は desassembler ce oul evite de re~ 
charger le ruban apres chaaue erreurs 

Four corier le ruban rerfore sur disques il faut utiliser 
l'utilitaire standard du T1690 3 le FUFé, 


XCALL FUFé arrel de l'utilitaire FUF6。 


XINFUT+TR>+ETAF definition Ou suerort d’entree 
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XOUTFUT snom- definition du fichier de sortie. L'extension 


Sa 
tI 
$I est reservee rour les fichiers hexa de 
l’Intel, 


XTRANSF effectue le transfert 


SEO. fin du travail 


4,0 Exemples d'utilisation de MADS 


+ 


desassemblase direct d'un ruban rerfore 


XCALL MALS arrel de MAIS, 

XEI TR selection du lecteur en entree, 
XLO LE selection de l’imrrimantes 
xIMALI initialisation et lecture 

- lecture du ruban ーーー | 
XMMATI marausse des instructions. 
XLMAD | listade de l’image memoires 

ーーー impression du resultat —“ ; i 

SEO. voila le travail 


Exemrle du desassemblase complet du moniteur 8008. 
SEO. 


XCALL FUFé creation d'un fichier disaue 
XINFUT>TRy+ETARO contenant le ruban hexa du moniteurs 
KOUTFUT sMONIT~3 fe Di 
XTRANSF 

ーーー Lecture du ruban 一 一 一 
xEOJ 


XCALL MATS 

KEI MONIT-*1y 02 

XFC TR 

XLO LF 

KIMAU, 2000 

xMMAT 

AMMAL SBAS marquage de tous les modules 
AMMAL s SOÛE du moniteurs 
XMMALI > 3967 

XMMAIDy 39A9 

XMMAL » 39114 

Sëll: 3A00 

XMMALI » 3413 

AMMAL SALA 

XMMATIHy 3043 
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XMMALI » 3445 
XMMAII» SASF 
AMMAL » SAGE 
XMMALI » 3A9 1 
XMMAL» SAF 6 
XMMADYy 3068 
XMMAD y SRE 7 
XAMMAD y 3EDS 
SL Héi 

-== impression du desassemblase e=- 
xEOJ 


940 Exemrle de listade Produit ear MANS, 


mé | 0079 | CPM 
| 007A | JF7 007F 
: [007D | LAB 
e | 007€ | RET 
ーー 007F | DCL 
0060 | JMP 0703 0080 | oca 
0043 | LLI 32 2 0081 | JFS 0079 
0045 | LHI op 0084 | JMP 3C43 
0047 | LCI oi 0087 | LLI 33 3 
0049 | JMP 3080 0089 | LHI 00 
004C | LLT 30 0 | 0088 | LME 
004E | LHI 00 | [008C | RET 
0950 | LAM 008D | CPI 46 F 
0051 | INL D08F | RTZ 
0052 | LBM | 0090 | CPI 54 T 
0053 | LHA 0092 | JF2 3043 
0054 | LLB i 0095 |LAI 20 
0055 | RET 0097 | LLI 33 3 
0956 | CAL 004C 0099 | LHI 00 
0059 | LME 0098 | aon 
005A | CAL 3DEB 009C | LMA 
005D | LAH 009D | RET 
095E | LBL 009E | CAL 00A7 
005F | LLI 30 0 00AL | LLIE 33 3 
¿0961 | LHI op 00A3 | LHI 00 
0963 | LMA 00A5 | LEM 
0964 | INL 00A6 | RET 
0065 | LMB 00A7 | CPI 43 C 
0066 | RET 00A9 | RTZ 
0067 IN 61 A] [| ODAA | CPI SA 7 
0068 CFC 42 B| | OOAC | LBI o 
0969 IN 43 C| | OOAE | JTZ 00BF 
096A JMP 44 D} |0081 | LBI 10 
0968 IN 45 E||0083 | CPr 53 5 
006C JFZ 48 H| | 00B5 | JTZ 00BF 
006D ~=- GC L|]0088 | LBI 18 
006E | . IN 40 M|[|O00BA | CPI 50 P 
006F IN 49 1||00BC | JFZ 3C43 
0070 | CAL 3F44 | OOBF | LAB 
0073 | LBI 08 00C0 | JMP 0097 
0975 | LEI 6f 00C3 | CPI 08 
0077 | LHI 00 “| [DOCS | JTZ 055€ 
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ADE 
ADI 
JMP 


CAL 


CS 


w 


AAA レーーー デ ーーー 


c'est probébiement 
des données 


' ; 
c'est probablement 
du programme 


c'est sûrement 
l'odresse d'implantation 


http://www.artinfo-musinfo.org Artlnfo Musinfo # 28, mars 1978, page 20 / 56 


PAGE 8 


